<?xml version="1.0" encoding="UTF-8" ?>
<class name="UPNPDevice" inherits="Reference" category="Core" version="3.1">
	<brief_description>
		UPNP device.
	</brief_description>
	<description>
		UPNP device. See [UPNP] for UPNP discovery and utility functions. Provides low-level access to UPNP control commands. Allows to manage port mappings (port forwarding) and to query network information of the device (like local and external IP address and status). Note that methods on this class are synchronous and block the calling thread.
	</description>
	<tutorials>
	</tutorials>
	<demos>
	</demos>
	<methods>
		<method name="add_port_mapping" qualifiers="const">
			<return type="int">
			</return>
			<argument index="0" name="port" type="int">
			</argument>
			<argument index="1" name="port_internal" type="int" default="0">
			</argument>
			<argument index="2" name="desc" type="String" default="&quot;&quot;">
			</argument>
			<argument index="3" name="proto" type="String" default="&quot;UDP&quot;">
			</argument>
			<argument index="4" name="duration" type="int" default="0">
			</argument>
			<description>
				Adds a port mapping to forward the given external port on this [UPNPDevice] for the given protocol to the local machine. See [method UPNP.add_port_mapping].
			</description>
		</method>
		<method name="delete_port_mapping" qualifiers="const">
			<return type="int">
			</return>
			<argument index="0" name="port" type="int">
			</argument>
			<argument index="1" name="proto" type="String" default="&quot;UDP&quot;">
			</argument>
			<description>
				Deletes the port mapping identified by the given port and protocol combination on this device. See [method UPNP.delete_port_mapping].
			</description>
		</method>
		<method name="is_valid_gateway" qualifiers="const">
			<return type="bool">
			</return>
			<description>
				Returns [code]true[/code] if this is a valid IGD (InternetGatewayDevice) which potentially supports port forwarding.
			</description>
		</method>
		<method name="query_external_address" qualifiers="const">
			<return type="String">
			</return>
			<description>
				Returns the external IP address of this [UPNPDevice] or an empty string.
			</description>
		</method>
	</methods>
	<members>
		<member name="description_url" type="String" setter="set_description_url" getter="get_description_url">
			URL to the device description.
		</member>
		<member name="igd_control_url" type="String" setter="set_igd_control_url" getter="get_igd_control_url">
			IDG control URL.
		</member>
		<member name="igd_our_addr" type="String" setter="set_igd_our_addr" getter="get_igd_our_addr">
			Address of the local machine in the network connecting it to this [UPNPDevice].
		</member>
		<member name="igd_service_type" type="String" setter="set_igd_service_type" getter="get_igd_service_type">
			IGD service type.
		</member>
		<member name="igd_status" type="int" setter="set_igd_status" getter="get_igd_status" enum="UPNPDevice.IGDStatus">
			IGD status. See [enum IGDStatus].
		</member>
		<member name="service_type" type="String" setter="set_service_type" getter="get_service_type">
			Service type.
		</member>
	</members>
	<constants>
		<constant name="IGD_STATUS_OK" value="0" enum="IGDStatus">
			OK.
		</constant>
		<constant name="IGD_STATUS_HTTP_ERROR" value="1" enum="IGDStatus">
			HTTP error.
		</constant>
		<constant name="IGD_STATUS_HTTP_EMPTY" value="2" enum="IGDStatus">
			Empty HTTP response.
		</constant>
		<constant name="IGD_STATUS_NO_URLS" value="3" enum="IGDStatus">
			Returned response contained no URLs.
		</constant>
		<constant name="IGD_STATUS_NO_IGD" value="4" enum="IGDStatus">
			Not a valid IGD.
		</constant>
		<constant name="IGD_STATUS_DISCONNECTED" value="5" enum="IGDStatus">
			Disconnected.
		</constant>
		<constant name="IGD_STATUS_UNKNOWN_DEVICE" value="6" enum="IGDStatus">
			Unknown device.
		</constant>
		<constant name="IGD_STATUS_INVALID_CONTROL" value="7" enum="IGDStatus">
			Invalid control.
		</constant>
		<constant name="IGD_STATUS_MALLOC_ERROR" value="8" enum="IGDStatus">
			Memory allocation error.
		</constant>
		<constant name="IGD_STATUS_UNKNOWN_ERROR" value="9" enum="IGDStatus">
			Unknown error.
		</constant>
	</constants>
</class>
